Welcome _gtk_tree_view_column_get_cell_at_pos to the second dimension
authorKristian Rietveld <kris@gtk.org>
Sun, 12 Dec 2010 14:22:49 +0000 (15:22 +0100)
committerKristian Rietveld <kris@gtk.org>
Sun, 12 Dec 2010 14:22:49 +0000 (15:22 +0100)
gtk/gtktreeprivate.h
gtk/gtktreeview.c
gtk/gtktreeviewcolumn.c

index be630f8be082bd64a3d2eabd3a89960840d84595..9fe2074a0010a58be83eada300b9ffbe39ff5f22 100644 (file)
@@ -122,7 +122,9 @@ gboolean _gtk_tree_view_column_cell_event   (GtkTreeViewColumn  *tree_column,
 gboolean          _gtk_tree_view_column_has_editable_cell(GtkTreeViewColumn  *column);
 GtkCellRenderer  *_gtk_tree_view_column_get_edited_cell  (GtkTreeViewColumn  *column);
 GtkCellRenderer  *_gtk_tree_view_column_get_cell_at_pos  (GtkTreeViewColumn  *column,
-                                                         gint                x);
+                                                          GdkRectangle       *cell_area,
+                                                          gint                x,
+                                                          gint                y);
 
 void             _gtk_tree_view_column_cell_render      (GtkTreeViewColumn  *tree_column,
                                                          cairo_t            *cr,
index fd010fd74b57827a7759c7910799a0c48c614ff8..5833be63d289d9897252968c6da95aadb330f86f 100644 (file)
@@ -3128,9 +3128,15 @@ gtk_tree_view_button_press (GtkWidget      *widget,
           if ((event->state & GDK_SHIFT_MASK) == GDK_SHIFT_MASK)
             tree_view->priv->shift_pressed = TRUE;
 
-
-         /* This needs an x and a y ! */
-          focus_cell = _gtk_tree_view_column_get_cell_at_pos (column, event->x - background_area.x);
+          /* We update the focus cell here, this is also needed if the
+           * column does not contain an editable cell.  In this case,
+           * GtkCellArea did not receive the event for processing (and
+           * could not update the focus cell).
+           */
+          focus_cell = _gtk_tree_view_column_get_cell_at_pos (column,
+                                                              &cell_area,
+                                                              event->x,
+                                                              event->y);
 
           if (focus_cell)
             gtk_tree_view_column_focus_cell (column, focus_cell);
index fe6e5f58cc921905942f0172a60602d6472be2bd..fd5eb1c6cfb47577d9227a9a4c048e0c27e33927 100644 (file)
@@ -1472,34 +1472,19 @@ _gtk_tree_view_column_get_edited_cell (GtkTreeViewColumn *column)
 
 GtkCellRenderer *
 _gtk_tree_view_column_get_cell_at_pos (GtkTreeViewColumn *column,
-                                       gint               x)
+                                       GdkRectangle      *cell_area,
+                                       gint               x,
+                                       gint               y)
 {
-  GList *list;
-  GList *cell;
   GtkCellRenderer *match = NULL;
   GtkTreeViewColumnPrivate *priv = column->priv;
 
-  list = gtk_cell_layout_get_cells (GTK_CELL_LAYOUT (column));
-  for (cell = list; cell; cell = cell->next)
-    {
-      GdkRectangle zero_cell_area = { 0, };
-      GdkRectangle allocation;
-
-      gtk_cell_area_get_cell_allocation (priv->cell_area,
-                                         priv->cell_area_context,
-                                         priv->tree_view,
-                                         cell->data,
-                                         &zero_cell_area,
-                                         &allocation);
-
-      if (allocation.x <= x && x <= allocation.x + allocation.width)
-        {
-          match = cell->data;
-          break;
-        }
-    }
-
-  g_list_free (list);
+  match = gtk_cell_area_get_cell_at_position (priv->cell_area,
+                                              priv->cell_area_context,
+                                              priv->tree_view,
+                                              cell_area,
+                                              x, y,
+                                              NULL);
 
   return match;
 }